# Introducció als Ordinadors: Capítol 2: REGISTRES DE LA CPU



#### Registres

- Conjunt d'elements biestables governats per el mateix clock.
- Un registre és una memòria d'alta velocitat i poca capacitat integrada en el processador que permet guardar temporalment i accedir a dades
- •Sincronisme:
- •Latch: actiu per rivells (no pot utilitzar-se per operacions del tipus Rj <=f(Rj, Ri)
- •Flip-Flop: actiu per flancs (edge-triggered)



n elements = n bits



### Registres

### LATCH

- -Quan el serval de rellotge està habilitat, l'entrada D passa a la sortida Q
- -Es fonamenta en un biestable SR, sincronitzat amb un senyal de rellotge



| Clk | D | Q |
|-----|---|---|
| 0   | 0 | Q |
| 0   | 1 | Q |
| 1.  | 0 | 0 |
| 1   | 1 | 1 |

### Registres

# Flip flop actiu per flanc (edge-triggered)

Només per net els canvis durant el temps de transició del senyal de clk -elimina sorolls

-elimina problemes de transicions en els flip-flops



El canvi es produeix en la transició 0-1 (rise time) o 1-0 (fall time)



#### Latch vs. Flip-Flop





#### Latch

- Actiu per nivells
- Útil per guardar
- No útil per Reg.Desplaçament
- Asincrònic
- •No útil per: font i destí alhora

### Flip-Flop

- Activ per canvis de nivells
- •Útil per guardar
- •Útil per Reg.Desplaçament
- •sincrònic



#### Nivell RTL (Register Transfer Level)

Disseny de sistemes digitals **sincrònics** Les operacions són **RTL** 

$$R_{i} \leftarrow R_{j} * R_{k}$$
Registre desti Registres font
Indica **transferència**, que es produeix quan arriba el flanc actiu del **clk**

Indica funció combinacional. El valor és estable quan les 2 variables ho són (retard)



Senyals sincrons d'habilitació i RESET

Introduïm un senyal d'habilitació (ENABLE) active high Introduïm un senyal de clear (RESET) active low



Hem de generar la funció que ens doni l'entrada D del flip flop en funció de les variables EN, /CLR i DI

La funció és:

D = /EN · /CLR·Q + EN·/CLR·DI

| EN / | CLR | DI | D      |
|------|-----|----|--------|
| 0>>  | 0   | 0  | 0      |
| 0    | 0   | 1  | 0      |
| 0    |     | 0  | Q      |
| 0    | 1   | 1  | Q<br>0 |
| 1    | 0   | 0  | 0      |
| 1    | 0   | 1) | 0      |
| 1    | 1   | 0  | 9      |
| 1    | 1   | 1  | (1)    |



### Estructura dels Registres

Funcionament correcte: governat per senyal d'habilitació



No aconsellable: habilitació actuant sobre el senyal de clk



#### Gated clock

- Retard
- •Pèrdua de sincronisme



BASIC

### Sincronisme en Registres







#### Lectura de REGISTRES



- •L'escriptura està controlada per els senyals E<sub>i</sub>.
- •Però si es vol llegir de dos registres i passar les daces a BUS es produeix un **conflicte de BUS**
- •Cal controlar l'accés a BUS



#### Multiplexat de les sortides dels registres (buffers-tristate)



Una alternativa és un MUX-n. Diferències de cost depenent del nombre de bits







Depenent de l'arquitectura del processador, el ensamblador pot actuar sobre els registres. Per exemple...

SUB R1,a1,a1

ADDI a1,a1,8

ADD a1,zero,a2

. . .

On

ADD Rd, Rs1, Rs2 ADDI Rd, Rs1, Immediat SUB Rd, Rs1, Rs2

L'OPERACIÓ DE LECTURA DE REGISTRES ÉS ASÍNCRONA L'OPERACIÓ D'ESCRIPTURA ÉS SÍNCRONA

El processador RISC-V el registre x0 sempre conté un 0

No es pot modificar



#### **RESET/CLEAR en Registres**

Generalment els flip-flops consten de RESET (CLEAR) asíncron





De la mateixa manera pot haver-hi senyal de PRESET

#### Elementos de memoria







Alguns cops és aconsellable usar un senyal de CLEAR sincrònic

1A

25



**POWER-ON-RESET** 





CLK

ENA

/CLR

SORT DA

25

00

Molts Microprocessadors porten incorporat el Power-On-Reset

30

Ė

00

Reset sinc.

B7

B7

Ė



### Registres de desplaçament



S0 i S1 són l'enable actuant al multiplexor

| Se | elecció |               |        | Senyals de Sortida |
|----|---------|---------------|--------|--------------------|
| S1 | S0      | Operac        | ió     | Qn-1 Qn-2 Q1 Q0    |
| 0  | 0       | Mantenir      | HOLD   | Qn-1 Qn-2 Q1 Q0    |
| 0  | 1       | Despl. Dreta  | SHR    | DL Qn-1 Q2 Q1      |
| 1  | 0       | Despl. Esquer | ra SHL | Qn-2 Qn-3 Q0 DR    |
| 1  | 1       | Càrrega       | LOAD   | Dn-1 Dn-2 D1 D0    |





Aplicació directa dels registres de desplaçament en ASM

Instruccions de l'estil:

En RISC-V tenim per exemple SLL Rd, Rs1, Rs2 => Desplaçament lògic de Rs1 [Rs2] bits i es guarda en Rd.

SLLI Rd, Rs1, Imm => deplaçament lògic de Rs1 Imm bits



### Funcionament del Registre de Desplaçament





# Conjunt de Registres (Register File)



### Conjunt de Registres de doble port

Dual-Port RF

Operacions  $R_i \leq R_j * R_k$ 



(a) Cel·la bàsica (CBD) doble port de lectura





Límits:

Àrea del CR creix aprox com el #ports<sup>2</sup>

Temps d'accés creix lineal. amb el #ports

Tenim dos tipus de registres:

- -Registres de propòsit general:
- -GPR (General Purpose Registers). Poden guardar qualsevol tipus de dada o adreça de memòria. Fonamentals en l'arquitectura Von Neumann, poden ser accessibles al programador o no.

- –Registres de propòsit específic:
- -Guarden informació específica de l'estat del sistema. No són accessibles al programador (a nivell d'escriptura, però si a nivell de lectura)



UNIVERSITAT

•Registres de propòsit general (ja vist)



# •Conjunt de registres RISC-V

| 31 0         |                                        |
|--------------|----------------------------------------|
| x0 / zero    | Alambrado a cero                       |
| x1 / ra      | Dirección de retorno                   |
| x2 / sp      | Stack pointer                          |
| x3 / gp      | Global pointer                         |
| x4 / tp      | Thread pointer                         |
| x5 / t0      | Temporal                               |
| x6 / t1      | Temporal                               |
| x7 / t2      | Temporal                               |
| x8 / s0 / fp | Saved register, frame pointer          |
| x9 / s1      | Saved register                         |
| x10 / a0     | Argumento de función, valor de retorno |
| x11 / a1     | Argumento de función, valor de retorno |
| x12 / a2     | Argumento de función                   |
| x13 / a3     | Argumento de función                   |
| x14 / a4     | Argumento de función                   |
| x15 / a5     | Argumento de función                   |
| x16 / a6     | Argumento de función                   |
| x17 / a7     | Argumento de función                   |
| x18 / s2     | Saved register                         |
| x19 / s3     | Saved register                         |
| x20 / s4     | Saved register                         |
| x21 / s5     | Saved register                         |
| x22 / s6     | Saved register                         |
| x23 / s7     | Saved register                         |
| x24 / s8     | Saved register                         |
| x25 / s9     | Saved register                         |
| x26 / s10    | Saved register                         |
| x27 / s11    | Saved register                         |
| x28 / t3     | Temporal                               |
| x29 / t4     | Temporal                               |
| x30 / t5     | Temporal                               |
| x31 / t6     | Temporal                               |
| 32           |                                        |
| 31 0         | 1                                      |
| pc           | ]                                      |
| 32           |                                        |



- •Registres específics
- PC (Program Counter). Ens indica la posició de memòria on es troba la seguent instrucció a executar. És un punter que ens indica l'adreça de memòria de la instrucció, NO EL CONTINGUT
- –IR (instruccion Register). Registre de propòsit específic on es guarda el CONTINGUT de l'adreça de memòria on apuntava el PC

IR 01010101

PC 00100101

| 01010101 | 00100100      |
|----------|---------------|
| 11001111 | 00100101 C PC |
| 00111111 | 00100110      |
| 11110000 | 00100111      |
| 11001111 | 00101000      |
| 00111111 | 00101001      |
| 00111111 | 00101010      |



- Registres especifics (II)
- -ACC (Acumulador). És un registre on es guarda el resultat de qualsevol operació que realitza la ALU (Unitat Aritmètic-lògica)
- -Pot ser explícit o implícit. En aquest darrer cas es fa servir com
- –ACC un registre de propòsit general
- -STAT (Status Reg.). És el registre on s'indiquen les incidències que es tenen al fer una determinada operación

### Exemple:

El contingut del registre R1 és 010011

El contingut del registre R2 és 100110



- •Registres específics
- -SEQ (Sequenciador) S'encarrega de realitzar operacions de control (el veurem més endevant)
- –MAR (Memory Address Register) Registre de adreces de memòria. Es fa servir de buffer per anar a una determinada posició de programa. Es el valor que es carrega al bus d'adreces
- -MBR (Memory Buffer Register) Registre buffer de dades. Es un buffer de dades. Accedeix per tant al bus de dades i serveix per intercambiar dades entre memòria i CPU.







- •Registres específics
- -SP (Stack Pointer) Registre que ens indica la posició de l'últim valor guardat a la PILA.





# Registres de la CPU: Exemple SiMR









# Registres de la CPU: RISC-V





# Registres de la CPU: Exemple Arquitectura ARM





# Registres de la CPU: Arquitectura IA-32

# intطا

#### PENTIUM® PROCESSOR 75/90/100/120/133/150/166/200





Figure 1. Pentium® Processor Block Diagram